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(57) ABSTRACT 

A system for configuring telemetry transponder cards uses a 
database of error checking protocol data structures, each con- 
taining data to implement at least one CCSDS protocol algo- 
rithm. Using a user interface, a user selects at least one telem- 
etry specific error checking protocol from the database. A 
compiler configures an FPGA with the data from the data 
structures to implement the error checking protocol. 
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SYSTEM FOR CONFIGURING MODULAR 
TEFEMETRY TRANSPONDERS 

FEDERAL RESEARCH STATEMENT 

The invention described herein was made by employees of 
the United States Government and may be manufactured and 
used by or for the Government of the United States of 
America for governmental purposes without the payment of 
any royalties thereon or therefore. 

CROSS REFERENCE 

This application is related to U.S. application Ser. No. 
13/369,704, entitled “Adaptable Transponder for Multiple 
Telemetry Systems” and filed on Feb. 9, 2012, which is 
hereby incorporated by reference in its entirety. 

FIELD OF INVENTION 

Present invention is a computer system configured with 
software and data necessary to create custom telemetry tran- 
sponder cards. 
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lated by the commands of a progra mmi ng language such as 
value, variable, function, or data structure. 

As used herein, the term “telemetry card” refers to a device 
configured with circuitry to perform telemetry encoding com- 
5 munications, command decoding communications as well as 
other SDR component functions. 

As used herein, the term “telemetry specific” means con- 
forming to the specifications necessary to interface with a 
specific on board flight computer. Such examples include the 
10 Forward Error Correcting (LDPC, Reed-Solomon, convolu- 
tional) codes, command synchronization with error detection, 
and increased spectral efficiency techniques. 

As used herein, the term “turbo code” means any code in 
the class of high-performance forward error-correction codes 
15 that are used in satellite communications and other applica- 
tions where designers seek to achieve reliable information 
transfer in the presence of data-corrupting noise. 

As used herein, the term “Viterbi algorithm” means the 
algorithm first conceived by Andrew Viterbi for decoding 
20 convolutional codes over digital communication links for 
encryption and auto-ranging. 

BACKGROUND 


BRIEF DESCRIPTION OF THE DRAWINGS 2 5 

FIG. 1 illustrates an exemplary embodiment of a computer 
system for configuring modular telemetry transponders. 

TERMS OF ART 30 

As used herein, the term “BCH error-checking protocol” 
means a CCSDS protocol that incorporates the BCH multi- 
level cyclic variable-length digital error-correcting code used 
to correct multiple random error patterns or any algorithmic 35 
and functional equivalent or derivative of this protocol. 

As usedherein, the term “CCSDS” means the Consultative 
Committee for Space Data Systems, which promulgates stan- 
dards for software used in space systems, including, but not 
limited to BCH error-checking protocol, Reed-Solomon pro- 40 
tocol, pseudo-randomization protocol, Low Density Parity 
Check (LDPC), Forward Error Correcting and Convolutional 
Encoding. 

As usedherein, the term “Field Programmable Gate Array” 
or “FPGA” means an integrated circuit that can be pro- 45 
grammed after manufacturing to perform the functions of an 
ASIC. 

As used herein, the tenn “pseudo-randomization protocol” 
or “PN generator” means a CCSDS protocol that synchro- 
nizes data by using a deterministic procedure that produces 50 
random numbers within definable limits or any algorithmic 
and functional equivalent or derivative of this protocol known 
in the art. 

As used herein, the tenn “Reed-Solomon protocol” means 
a CCSDS protocol that incorporates the non-binary cyclic 55 
error-correcting codes, or any algorithmic and functional 
equivalent or derivative of this Reed-Solomon protocol 
known in the art. Reed-Solomon codes are one type of BCH 
codes. 

As used herein, the tenn “software defined radio” or 60 
“SDR” means a radio co mmu nications system where com- 
ponents that have been typically implemented in hardware 
(such as mixers, filters, amplifiers, modulators/demodulators, 
and detectors) are instead implemented by means of software 
on an embedded computing device. 65 

As used herein, the term “telemetry application data 
object” means a telemetry specific entity that can be manipu- 


Telemetry refers to technology used by a satellite to trans- 
mit data to a monitoring station. Transponders, important 
devices in telemetry that receive signals and transmit the 
signals at different frequencies, still rely on technology dating 
back to the 1960s. 

Every telemetry transponder is configured to interface with 
specific on board flight computer hardware, and to perform 
specific error checking protocols. With the associated hard- 
ware necessary for the satellite to comply with the transpon- 
der, a typical NASA telemetry system costs $5 to $10 million 
dollars per satellite. 

Related U.S. patent application Ser. No. 13/369,704 dis- 
closes a modular telemetry system which can be rapidly 
deployed utilizing a modularly configured transponder which 
because it implements field programmable gate array (FPGA) 
and satellite defined radio (SDR) design principles. 

The transponder disclosed in U.S. patent application Ser. 
No. 13/369,704 is adaptable for all telemetry systems and 
telemetry communication needs that could be used for NASA 
missions (including lunar missions and missions to Mars), 
military intelligence, climate change studies, and emergency 
services such as fire, ambulance, and police services. 

There is an unmet need for a computer system which 
allows a user to efficiently reprogram transponder devices 
utilizing the principles of modular transponder design dis- 
closed in U.S. patent application Ser. No. 13/369,704. 

There is a need for a computer system specifically adapted 
to receive user selections and input regarding specific telem- 
etry applications and which can access and compile code 
necessary to create custom telemetry cards. 

There is a further need for a system which can create 
telemetry cards using principles disclosed in U.S. patent 
application Ser. No. 13/369,704 to efficiently configure 
telemetry transponders. 

This is a further need for a system which can be adapted to 
incorporate future developments and efficiencies with respect 
to telemetry card design and configuration. 

SUMMARY OF THE INVENTION 

The present invention is a computer system capable of 
reprogra mmin g telemetry cards for application specific error 
checking. The system is comprised of a server and database 
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containing a library of CCSDS protocol algorithms. The sys- 
tem further includes a user interface which allows a user to 
select at least one error checking protocol and a compiler 
which creates a compiled data object containing data for 
configuring at least one FPGA. The present invention allows 
a user to configure a telemetry card with a specific error 
checking or CCSDS protocol code as needed. 

DETAILED DESCRIPTION OF INVENTION 

For the purpose of promoting an understanding of the 
present invention, references are made in the text to exem- 
plary embodiments of system for configuring modular telem- 
etry transponders, only some of which are described herein. It 
should be understood that no limitations on the scope of the 
invention are intended by describing these exemplary 
embodiments. One of ordinary skill in the art will readily 
appreciate that alternate but functionally equivalent compo- 
nents, materials, and placement may be used. The inclusion of 
additional elements may be deemed readily apparent and 
obvious to one of ordinary skill in the art. Specific elements 
disclosed herein are not to be interpreted as limiting, but 
rather as a basis for the claims and as a representative basis for 
teaching one of ordinary skill in the art to employ the present 
invention. 

It should be understood that the drawing is not necessarily 
to scale; instead, emphasis has been placed upon illustrating 
the principles of the invention 

Moreover, the terms “substantially” or “approximately” as 
used herein may be applied to modify any quantitative repre- 
sentation that could pennissibly vary without resulting in a 
change in the basic function to which it is related. 

FIG. 1 illustrates an exemplary embodiment of system for 
configuring and/or reconfiguring a modular transponder 100. 
In the embodiment shown, system 100 includes a plurality of 
predetermined error checking protocols and various other 
CCSDS protocols in a database on a server. In the embodi- 
ment shown, Reed-Solomon 50a, PN generator 506, BCH 
encoder 50c, turbo encoder 50c/, convolution coder 50e, and 
various other CCSDS modules 50/"-506 are exemplary 
embodiments of predetermined error checking algorithms 
which may be programmed onto FPGA 40. In other embodi- 
ments, the database of predetermined error checking algo- 
rithms may include Viterbi, encryption, auto-ranging, other 
versions of the BCH error-correcting protocol or any other 
CCSDS compliant protocols. 

Graphical user interface (GUI) 15 allows a user to choose 
a specific protocol or code from a database of predetermined 
algorithms and convert them to compiled data object 18 to be 
programmed onto FPGA 40. This allows a user to choose an 
appropriate protocol for a specific telemetry application and 
configure it onto the FPGA of a telemetry card using off-the- 
shelf FPGA program software to embed the SDR IP to per- 
form specific objectives such as Forward Error Correcting, 
error detection, bit synchronization, etc. 

In the exemplary embodiment described above, a typical 
user interface may be Microsemi Corp ration’s Libero soft- 
ware package that allows the SDR IP to be designed, com- 
piled, optimized and incorporated into an FPGA. However, 
various other embodiments may use other software to design, 
compile and display protocols to be incorporated in the 
FPGA. 

What is claimed is: 

1. A system for configuring at least one reprogrammable 
telemetry card consisting of: 
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a plurality of non-uniform satellite telemetry systems, 
wherein each of said plurality of non-uniform satellite 
telemetry systems is an on-board satellite telemetry sys- 
tem; 

5 a single reprogrammable telemetry card which is config- 
ured with a plurality of software defined radio compo- 
nents common to all of said plurality of non-uniform 
satellite telemetry systems, wherein said plurality of 
software defined radio components is re-usable with 
each of said plurality of non-uniform satellite telemetry 
systems without modification, 

wherein said single reprogrammable telemetry card is fur- 
ther configured with an FPGA which may be pro- 
15 grammed with a specific error checking protocol which 
corresponds to a telemetry error checking protocol 
applicable to at least one specific telemetry system of 
said plurality of non-uniform telemetry systems; and 

a user interface configured to display a list of satellite 
20 telemetry system types, wherein each satellite telemetry 
system type corresponds to said specific error checking 
protocol, and wherein said user interface is further con- 
figured to receive a user input corresponding to said 
specific error checking protocol and to update at least 
25 one value within at least one compiler software object, 

wherein said at least one value to invokes a programming 
function to program said FPGA of said single repro- 
grammable telemetry card with said specific error 
checking protocol corresponding to said user input with- 
30 out altering said plurality of software radio defined 
objects so that said single reprogrammable telemetry 
card may be reused with other satellite telemetry sys- 
tems, 

wherein said user interface is operatively coupled with a 
35 compiler to update an error checking protocol value in 
said at least one compiler software object wherein said 
updated error checking protocol value in said compiler 
software object invokes an updating fimction which 
updates said specific error checking protocol corre- 
40 sponding to said user input, wherein said plurality of 
software radio defined objects are not altered and remain 
useable within each of said plurality of non-uniform 
satellite telemetry systems. 

2. The system of claim 1 wherein said list of satellite 
45 telemetry system types includes data structures for at least 

two satellite telemetry system types. 

3. The system of claim 1 wherein said user-selected value 
is configured with data to perform Reed-Solomon error 
checking protocol. 

50 4. The system of claim 1 wherein said user-selected value 

is configured with data to perform a PN generator error check- 
ing protocol. 

5. The system of claim 1 wherein said specific error check- 
ing protocol is configured with data to perform a turbo code. 
55 6 . The system of claim 1 wherein said specific error check- 

ing protocol is configured with data to perform a Viterbi 
algorithm. 

7. The system of claim 1 wherein said specific error check- 
ing protocol is configured with data to perform encryption. 
60 8. The system of claim 1 wherein said specific error check- 

ing protocol is configured with data to perform auto-ranging. 

9. The system of claim 1 wherein said specific error check- 
ing protocol is configured with data to perform BCH error- 
correcting protocol. 

65 10. The system of claim 9 wherein said specific error 

checking protocol is configured with data to perform other 
versions of said BCH error-correcting protocol. 
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11. The system of claim 1 wherein said compiler is further 
configured with an FPGA with multiple error checking algo- 
rithms. 

12. The system of claim 1, which further includes software 
which is CCSDS compatible with existing earth based ground 5 
stations. 

13. A method for configuring at least one telemetry card 
consisting of: 

configuring a single reprogrammable telemetry card with a 
plurality of software defined radio components common 
to a plurality of non-uniform satellite telemetry systems; 

displaying a list of satellite telemetry system types, 
wherein each satellite telemetry system type corre- 
sponds to a specific error checking protocol; 

receiving a user input corresponding to said specific error 
checking protocol; 

invoking a programming function to program an FPGA of 
said single reprogrammable telemetry card with said 
specific error checking protocol corresponding to said 
user input, wherein said plurality of software radio 
defined obj ects are not altered and remain useable within 
each of said plurality of non-uniform satellite telemetry 
systems; 

utilizing a compiler to update at least one error checking 
protocol value within at least one compiler software 
object; and 

invoking an updating function which updates said specific 
error checking protocol corresponding to said user 
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input, wherein said plurality of software radio defined 
obj ects are not altered and remain useable within each of 
said plurality of non-uniform satellite telemetry sys- 
tems. 

14. The method of claim 13 which further includes the step 
of programming said FPGA to perform Reed-Solomon error 
checking protocol. 

15. The method of claim 13 which further includes the step 
of programming said FPGA to perform a PN generator error 
checking protocol. 

16. The method of claim 13 which further includes the step 
of programming said FPGA to perform a turbo code algo- 
rithm. 

17. The method of claim 13 which further includes the step 
of programming said FPGA to perform a Viterbi algorithm. 

18. The method of claim 13 which further includes the step 
of programming said FPGA to perform encryption. 

19. The method of claim 13 winch further includes the step 
20 of programming said FPGA to perform auto-ranging. 

20. The method of claim 13 which further includes the step 
of programming said FPGA to perform BCF1 error-correcting 
protocol. 

21 . The method of claim 20 which further includes the step 
25 of programming said FPGA to perform multiple alternative 

versions of said BCF1 error-correcting protocol. 



